main {
    width: 100vw;
    height: 100vh;
    background-image: url('../../src/bg.jpg');
    background-size: 100% 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

article {
    width: 60%;
    height: 60%;
    background-color: rgba(0, 0, 0, .4);
    border-radius: 10px;
    box-shadow: 0px 0px 30px black;
    padding: 2em;
    display: flex;
    flex-direction: column;
    align-items: center;
}
aside {
    width: 100%;
    height: 30%;
    display: flex;
    justify-content: center;
    align-items: center;
}

h1 {
    font-size: 3em;
    color: #555;
    transition: .3s;
}

.form{
    width: 100%;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-around;
}